Data Balance Analysis on Spark
Context
Data Balance Analysis is relevant for gaining an overall understanding of datasets, but it becomes essential when thinking about building AI systems in a responsible way, especially in terms of fairness.
AI systems can sometimes exhibit unwanted, unfair behaviors. These behaviors can cause fairness-related harms that affect various groups of people. They may amplify the marginalization of particular groups whose needs and contexts are often overlooked during AI development and deployment. Fairness-related harms can have varying severities, and the cumulative impact of even seemingly non-severe harms can be burdensome.
Fairness-related harms include:
- Allocation harms: When an AI system extends or withholds opportunities or resources in ways that negatively impact people’s lives.
- Quality of service harms: When an AI system does not work as well for one group of people as it does for another.
- Stereotyping harms: When an AI system makes unfair generalizations about groups of people and reinforces negative stereotypes.
- Demeaning harms: When an AI system is actively derogatory or offensive.
- Over/underrepresentation harms: When an AI system over/underrepresents some groups of people or may even erase some groups entirely.
Note: Because fairness in AI is fundamentally a sociotechnical challenge, it's often impossible to fully “de-bias” an AI system. Instead, teams tasked with developing and deploying AI systems must work to identify, measure, and mitigate fairness-related harms as much as possible. Data Balance Analysis is a tool to help do so, in combination with others.
Data Balance Analysis consists of a combination of three groups of measures: Feature Balance Measures, Distribution Balance Measures, and Aggregate Balance Measures.
In summary, Data Balance Analysis, when used as a step for building ML models, has the following benefits:
- It reduces the costs of building ML through the early identification of data representation gaps. Before proceeding to train their models, data scientists can seek mitigation steps such as collecting more data, following a specific sampling mechanism, creating synthetic data, and so on.
- It enables easy end-to-end debugging of ML systems in combination with the RAI Toolbox by providing a clear view of model-related issues versus data-related issues.
Examples
Usage
Data Balance Analysis currently supports three transformers in the synapse.ml.exploratory
namespace:
- FeatureBalanceMeasure - supervised (requires label column)
- DistributionBalanceMeasure - unsupervised (doesn't require label column)
- AggregateBalanceMeasure - unsupervised (doesn't require label column)
Import all three transformers.
For example:
from synapse.ml.exploratory import AggregateBalanceMeasure, DistributionBalanceMeasure, FeatureBalanceMeasure
Load your dataset, define features of interest, and ensure that the label column is binary. The
FeatureBalanceMeasure
transformer currently only supports binary labels, but support for numerical labels will be added soon.For example:
import pyspark.sql.functions as F
features = ["race", "sex"]
label = "income"
df = spark.read.parquet("wasbs://publicwasb@mmlspark.blob.core.windows.net/AdultCensusIncome.parquet")
# Convert the "income" column from {<=50K, >50K} to {0, 1} to represent our binary classification label column
df = df.withColumn(label, F.when(F.col(label).contains("<=50K"), F.lit(0)).otherwise(F.lit(1)))Create a
FeatureBalanceMeasure
transformer and callsetSensitiveCols
to set the list of sensitive features and callsetLabelCol
to set the binary label column. Then, call thetransform
method with your dataset and visualize the resulting dataframe.For example:
feature_balance_measures = (
FeatureBalanceMeasure()
.setSensitiveCols(features)
.setLabelCol(label)
.transform(df)
)
feature_balance_measures.show(truncate=False)Create a
DistributionBalanceMeasure
transformer and callsetSensitiveCols
to set the list of sensitive features. Then, call thetransform
method with your dataset and visualize the resulting dataframe.For example:
distribution_balance_measures = (
DistributionBalanceMeasure()
.setSensitiveCols(features)
.transform(df)
)
distribution_balance_measures.show(truncate=False)Create a
AggregateBalanceMeasure
transformer and callsetSensitiveCols
to set the list of sensitive features. Then, call thetransform
method with your dataset and visualize the resulting dataframe.For example:
aggregate_balance_measures = (
AggregateBalanceMeasure()
.setSensitiveCols(features)
.transform(df)
)
aggregate_balance_measures.show(truncate=False)
Note: If you're running this notebook in a Spark environment such as Azure Synapse or Databricks, then you can easily visualize the imbalance measures by calling the built-in plotting features display()
.
Measure Explanations
Feature Balance Measures
Feature Balance Measures allow us to see whether each combination of sensitive feature is receiving the positive outcome (true prediction) at balanced probability.
In this context, we define a feature balance measure, called the parity, for label y. It is the difference between the association metrics of two different sensitive classes , with respect to the association metric . That is:
Using the dataset, we can see if the various sexes and races are receiving >50k income at equal or unequal rates.
Note: Many of these metrics were influenced by this paper Measuring Model Biases in the Absence of Ground Truth.
Association Metric | Family | Description | Interpretation/Formula | Reference |
---|---|---|---|---|
Statistical Parity | Fairness | Proportion of each segment of a protected class (gender, for example) that should receive the positive outcome at equal rates. | Closer to zero means better parity. . | Link |
Pointwise Mutual Information (PMI), normalized PMI | Entropy | The PMI of a pair of feature values (ex: Gender=Male and Gender=Female) quantifies the discrepancy between the probability of their coincidence given their joint distribution and their individual distributions (assuming independence). | Range (normalized) . -1 for no co-occurrences. 0 for co-occurrences at random. 1 for complete co-occurrences. | Link |
Sorensen-Dice Coefficient (SDC) | Intersection-over-Union | Used to gauge the similarity of two samples. Related to F1 score. | Equals twice the number of elements common to both sets divided by the sum of the number of elements in each set. | Link |
Jaccard Index | Intersection-over-Union | Similar to SDC, gauges the similarity and diversity of sample sets. | Equals the size of the intersection divided by the size of the union of the sample sets. | Link |
Kendall Rank Correlation | Correlation and Statistical Tests | Used to measure the ordinal association between two measured quantities. | High when observations have a similar rank and low when observations have a dissimilar rank between the two variables. | Link |
Log-Likelihood Ratio | Correlation and Statistical Tests | Calculates the degree to which data supports one variable versus another. Log of the likelihood ratio, which gives the probability of correctly predicting the label in ratio to probability of incorrectly predicting label. | If likelihoods are similar, it should be close to 0. | Link |
t-test | Correlation and Statistical Tests | Used to compare the means of two groups (pairwise). | Value looked up in t-Distribution tell if statistically significant or not. | Link |
Distribution Balance Measures
Distribution Balance Measures allow us to compare our data with a reference distribution (currently only uniform distribution is supported as a reference distribution). They are calculated per sensitive column and don't depend on the label column.
For example, let's assume we have a dataset with nine rows and a Gender column, and we observe that:
- "Male" appears four times
- "Female" appears three times
- "Other" appears twice
Assuming the uniform distribution:
Feature Value | Observed Count | Reference Count | Observed Probability | Reference Probabiliy |
---|---|---|---|---|
Male | 4 | 9/3 = 3 | 4/9 = 0.44 | 3/9 = 0.33 |
Female | 3 | 9/3 = 3 | 3/9 = 0.33 | 3/9 = 0.33 |
Other | 2 | 9/3 = 3 | 2/9 = 0.22 | 3/9 = 0.33 |
We can use distance measures to find out how far our observed and reference distributions of these feature values are. Some of these distance measures include:
Measure | Description | Interpretation | Reference |
---|---|---|---|
KL Divergence | Measure of how one probability distribution is different from a second, reference probability distribution. Measure of the information gained when one revises one's beliefs from the prior probability distribution Q to the posterior probability distribution P. In other words, it is the amount of information lost when Q is used to approximate P. | Non-negative. 0 means P = Q. | Link |
JS Distance | Measuring the similarity between two probability distributions. Symmetrized and smoothed version of the Kullback–Leibler (KL) divergence. Square root of JS Divergence. | Range [0, 1]. 0 means perfectly same to balanced distribution. | Link |
Wasserstein Distance | This distance is also known as the earth mover’s distance, since it can be seen as the minimum amount of “work” required to transform u into v, where “work” is measured as the amount of distribution weight that must be moved multiplied by the distance it has to be moved. | Non-negative. 0 means P = Q. | Link |
Infinity Norm Distance | Distance between two vectors is the greatest of their differences along any coordinate dimension. Also called Chebyshev distance or chessboard distance. | Non-negative. 0 means same distribution. | Link |
Total Variation Distance | It is equal to half the L1 (Manhattan) distance between the two distributions. Take the difference between the two proportions in each category, add up the absolute values of all the differences, and then divide the sum by 2. | Non-negative. 0 means same distribution. | Link |
Chi-Squared Test | The chi-square test tests the null hypothesis that the categorical data has the given frequencies given expected frequencies in each category. | p-value gives evidence against null-hypothesis that difference in observed and expected frequencies is by random chance. | Link |
Aggregate Balance Measures
Aggregate Balance Measures allow us to obtain a higher notion of inequality. They're calculated on the set of all sensitive columns and don't depend on the label column.
These measures look at distribution of records across all combinations of sensitive columns. For example, if Sex and Race are specified as sensitive features, it then tries to quantify imbalance across all combinations of the two specified features - (Male, Black), (Female, White), (Male, Asian-Pac-Islander), etc.
Measure | Description | Interpretation | Reference |
---|---|---|---|
Atkinson Index | It presents the percentage of total income that a given society would have to forego in order to have more equal shares of income between its citizens. This measure depends on the degree of societal aversion to inequality (a theoretical parameter decided by the researcher). A higher value entails greater social utility or willingness by individuals to accept smaller incomes in exchange for a more equal distribution. An important feature of the Atkinson index is that it can be decomposed into within-group and between-group inequality. | Range . 0 if perfect equality. 1 means maximum inequality. In our case, it is the proportion of records for a sensitive columns’ combination. | Link |
Theil T Index | GE(1) = Theil's T and is more sensitive to differences at the top of the distribution. The Theil index is a statistic used to measure economic inequality. The Theil index measures an entropic "distance" the population is away from the "ideal" egalitarian state of everyone having the same income. | If everyone has the same income, then T_T equals 0. If one person has all the income, then T_T gives the result . 0 means equal income and larger values mean higher level of disproportion. | Link |
Theil L Index | GE(0) = Theil's L and is more sensitive to differences at the lower end of the distribution. Logarithm of (mean income)/(income i), over all the incomes included in the summation. It is also referred to as the mean log deviation measure. Because a transfer from a larger income to a smaller one will change the smaller income's ratio more than it changes the larger income's ratio, the transfer-principle is satisfied by this index. | Same interpretation as Theil T Index. | Link |
Mitigation
It will not be a stretch to say that every real-world dataset has caveats, biases, and imbalances. Data collection is costly. Data Imbalance mitigation or de-biasing data is an area of research. There are many techniques available at various stages of ML lifecycle: during pre-processing, in-processing, and post processing. Here we outline a couple of pre-processing techniques -
Resampling
Resampling involves under-sampling from majority class and over-sampling from minority class. A naïve way to over-sample would be to duplicate records. Similarly, to under-sample one could remove records at random.
Caveats:
- Under-sampling may remove valuable information.
- Over-sampling may cause overfitting and poor generalization on test set.
There are smarter techniques to under-sample and over-sample in literature and implemented in Python’s imbalanced-learn package.
For example, we can cluster the records of the majority class, and do the under-sampling by removing records from each cluster, thus seeking to preserve information.
One technique of under-sampling is use of Tomek Links. Tomek links are pairs of instances that are very close but of opposite classes. Removing the instances of the majority class of each pair increases the space between the two classes, facilitating the classification process. A similar way to under-sample majority class is using Near-Miss. It first calculates the distance between all the points in the larger class with the points in the smaller class. When two points belonging to different classes are very close to each other in the distribution, this algorithm eliminates the datapoint of the larger class thereby trying to balance the distribution.
In over-sampling, instead of creating exact copies of the minority class records, we can introduce small variations into those copies, creating more diverse synthetic samples. This technique is called SMOTE (Synthetic Minority Oversampling Technique). It randomly picks a point from the minority class and computes the k-nearest neighbors for this point. The synthetic points are added between the chosen point and its neighbors.
Reweighting
There is an expected and observed value in each table cell. The weight is the value of expected / observed. Reweighting is easy to extend to multiple features with more than two groups. The weights are then incorporated in loss function of model training.